home *** CD-ROM | disk | FTP | other *** search
/ MACD 5 / MACD 5.bin / workbench / blankery / blanker / source / blankers / text / text.c < prev    next >
C/C++ Source or Header  |  1993-07-03  |  7KB  |  267 lines

  1. /*
  2.  *  Source machine generated by GadToolsBox V2.0b
  3.  *  which is (c) Copyright 1991-1993 Jaba Development
  4.  *
  5.  *  GUI Designed by : Michael D. Bayne
  6.  */
  7.  
  8. #include <exec/types.h>
  9. #include <intuition/intuition.h>
  10. #include <intuition/classes.h>
  11. #include <intuition/classusr.h>
  12. #include <intuition/imageclass.h>
  13. #include <intuition/gadgetclass.h>
  14. #include <libraries/gadtools.h>
  15. #include <graphics/displayinfo.h>
  16. #include <graphics/gfxbase.h>
  17. #include <clib/exec_protos.h>
  18. #include <clib/intuition_protos.h>
  19. #include <clib/gadtools_protos.h>
  20. #include <clib/graphics_protos.h>
  21. #include <clib/utility_protos.h>
  22. #include <string.h>
  23. #include <clib/diskfont_protos.h>
  24.  
  25. #include "Text.h"
  26.  
  27. struct Screen         *Scr = NULL;
  28. UBYTE                 *PubScreenName = NULL;
  29. APTR                   VisualInfo = NULL;
  30. struct Window         *TextWnd = NULL;
  31. struct Gadget         *TextGList = NULL;
  32. struct IntuiMessage    TextMsg;
  33. struct Gadget         *TextGadgets[10];
  34. UWORD                  TextLeft = 0;
  35. UWORD                  TextTop = 12;
  36. UWORD                  TextWidth = 425;
  37. UWORD                  TextHeight = 63;
  38. UBYTE                 *TextWdt = (UBYTE *)"Text Prefs";
  39. struct TextAttr       *Font, Attr;
  40. UWORD                  FontX, FontY;
  41. UWORD                  OffX, OffY;
  42. struct TextFont       *TextFont = NULL;
  43.  
  44. UBYTE *SWITCH0Labels[] = {
  45.     (UBYTE *)"String",
  46.     (UBYTE *)"File",
  47.     NULL };
  48.  
  49. UBYTE *CYCLE0Labels[] = {
  50.     (UBYTE *)"Cycle",
  51.     (UBYTE *)"Random",
  52.     (UBYTE *)"White",
  53.     (UBYTE *)"Copper",
  54.     NULL };
  55.  
  56. UWORD TextGTypes[] = {
  57.     STRING_KIND,
  58.     BUTTON_KIND,
  59.     TEXT_KIND,
  60.     BUTTON_KIND,
  61.     BUTTON_KIND,
  62.     NUMBER_KIND,
  63.     SLIDER_KIND,
  64.     CYCLE_KIND,
  65.     CYCLE_KIND,
  66.     BUTTON_KIND
  67. };
  68.  
  69. struct NewGadget TextNGad[] = {
  70.     106, 2, 314, 14, NULL, NULL, GD_TXT, 0, NULL, (APTR)TXTClicked,
  71.     5, 18, 95, 13, (UBYTE *)"_Font...", NULL, GD_FONT, PLACETEXT_IN, NULL, (APTR)FONTClicked,
  72.     106, 18, 260, 13, NULL, NULL, GD_FTXT, 0, NULL, NULL,
  73.     5, 48, 101, 13, (UBYTE *)"_Ok", NULL, GD_OK, PLACETEXT_IN, NULL, (APTR)OKClicked,
  74.     162, 48, 101, 13, (UBYTE *)"_Test", NULL, GD_TEST, PLACETEXT_IN, NULL, (APTR)TESTClicked,
  75.     371, 18, 49, 13, NULL, NULL, GD_FSIZE, 0, NULL, NULL,
  76.     106, 33, 157, 13, (UBYTE *)"_Speed", NULL, GD_SPEED, PLACETEXT_LEFT, NULL, (APTR)SPEEDClicked,
  77.     5, 2, 95, 14, NULL, NULL, GD_SWITCH, 0, NULL, (APTR)SWITCHClicked,
  78.     319, 33, 101, 13, NULL, NULL, GD_CYCLE, 0, NULL, (APTR)CYCLEClicked,
  79.     319, 48, 101, 13, (UBYTE *)"_Cancel", NULL, GD_CANCEL, PLACETEXT_IN, NULL, (APTR)CANCELClicked
  80. };
  81.  
  82. ULONG TextGTags[] = {
  83.     (GTST_MaxChars), 128, (TAG_DONE),
  84.     (GT_Underscore), '_', (TAG_DONE),
  85.     (GTTX_Border), TRUE, (TAG_DONE),
  86.     (GT_Underscore), '_', (TAG_DONE),
  87.     (GT_Underscore), '_', (TAG_DONE),
  88.     (GTNM_Border), TRUE, (TAG_DONE),
  89.     (GTSL_Min), 1, (GTSL_Max), 50, (GTSL_Level), 10, (GTSL_MaxLevelLen), 4, (GTSL_LevelFormat), (ULONG)"%3ld", (GTSL_LevelPlace), (PLACETEXT_RIGHT), (PGA_Freedom), LORIENT_HORIZ, (GA_RelVerify), TRUE, (GT_Underscore), '_', (TAG_DONE),
  90.     (GTCY_Labels), (ULONG)&SWITCH0Labels[ 0 ], (TAG_DONE),
  91.     (GTCY_Labels), (ULONG)&CYCLE0Labels[ 0 ], (TAG_DONE),
  92.     (GT_Underscore), '_', (TAG_DONE)
  93. };
  94.  
  95. static UWORD ComputeX( UWORD value )
  96. {
  97.     return(( UWORD )((( FontX * value ) + 4 ) / 8 ));
  98. }
  99.  
  100. static UWORD ComputeY( UWORD value )
  101. {
  102.     return(( UWORD )((( FontY * value ) + 4 ) / 8 ));
  103. }
  104.  
  105. static void ComputeFont( UWORD width, UWORD height )
  106. {
  107.     Forbid();
  108.     Font = &Attr;
  109.     Font->ta_Name = (STRPTR)GfxBase->DefaultFont->tf_Message.mn_Node.ln_Name;
  110.     Font->ta_YSize = FontY = GfxBase->DefaultFont->tf_YSize;
  111.     FontX = GfxBase->DefaultFont->tf_XSize;
  112.     Permit();
  113.  
  114.     OffX = Scr->WBorLeft;
  115.     OffY = Scr->RastPort.TxHeight + Scr->WBorTop + 1;
  116.  
  117.     if ( width && height ) {
  118.         if (( ComputeX( width ) + OffX + Scr->WBorRight ) > Scr->Width )
  119.             goto UseTopaz;
  120.         if (( ComputeY( height ) + OffY + Scr->WBorBottom ) > Scr->Height )
  121.             goto UseTopaz;
  122.     }
  123.     return;
  124.  
  125. UseTopaz:
  126.     Font->ta_Name = (STRPTR)"topaz.font";
  127.     FontX = FontY = Font->ta_YSize = 8;
  128. }
  129.  
  130. int SetupScreen( void )
  131. {
  132.     if ( ! ( Scr = LockPubScreen( PubScreenName )))
  133.         return( 1L );
  134.  
  135.     ComputeFont( 0, 0 );
  136.  
  137.     if ( ! ( VisualInfo = GetVisualInfo( Scr, TAG_DONE )))
  138.         return( 2L );
  139.  
  140.     return( 0L );
  141. }
  142.  
  143. void CloseDownScreen( void )
  144. {
  145.     if ( VisualInfo ) {
  146.         FreeVisualInfo( VisualInfo );
  147.         VisualInfo = NULL;
  148.     }
  149.  
  150.     if ( Scr        ) {
  151.         UnlockPubScreen( NULL, Scr );
  152.         Scr = NULL;
  153.     }
  154. }
  155.  
  156. int HandleTextIDCMP( void )
  157. {
  158.     struct IntuiMessage    *m;
  159.     int            (*func)();
  160.     BOOL            running = TRUE;
  161.  
  162.     while( m = GT_GetIMsg( TextWnd->UserPort )) {
  163.  
  164.         CopyMem(( char * )m, ( char * )&TextMsg, (long)sizeof( struct IntuiMessage ));
  165.  
  166.         GT_ReplyIMsg( m );
  167.  
  168.         switch ( TextMsg.Class ) {
  169.  
  170.             case    IDCMP_REFRESHWINDOW:
  171.                 GT_BeginRefresh( TextWnd );
  172.                 GT_EndRefresh( TextWnd, TRUE );
  173.                 break;
  174.  
  175.             case    IDCMP_VANILLAKEY:
  176.                 running = TextVanillaKey();
  177.                 break;
  178.  
  179.             case    IDCMP_GADGETUP:
  180.             case    IDCMP_GADGETDOWN:
  181.                 func = ( void * )(( struct Gadget * )TextMsg.IAddress )->UserData;
  182.                 running = func();
  183.                 break;
  184.         }
  185.     }
  186.     return( running );
  187. }
  188.  
  189. int OpenTextWindow( void )
  190. {
  191.     struct NewGadget    ng;
  192.     struct Gadget    *g;
  193.     UWORD        lc, tc;
  194.     UWORD        wleft = TextLeft, wtop = TextTop, ww, wh;
  195.  
  196.     ComputeFont( TextWidth, TextHeight );
  197.  
  198.     ww = ComputeX( TextWidth );
  199.     wh = ComputeY( TextHeight );
  200.  
  201.     wleft = ( Scr->Width - ww )/2 - Scr->WBorRight;
  202.     wtop = ( Scr->Height - wh - Font->ta_YSize )/2 - Scr->WBorBottom;
  203.  
  204.     if ( ! ( TextFont = OpenDiskFont( Font )))
  205.         return( 5L );
  206.  
  207.     if ( ! ( g = CreateContext( &TextGList )))
  208.         return( 1L );
  209.  
  210.     for( lc = 0, tc = 0; lc < Text_CNT; lc++ ) {
  211.  
  212.         CopyMem((char * )&TextNGad[ lc ], (char * )&ng, (long)sizeof( struct NewGadget ));
  213.  
  214.         ng.ng_VisualInfo = VisualInfo;
  215.         ng.ng_TextAttr   = Font;
  216.         ng.ng_LeftEdge   = OffX + ComputeX( ng.ng_LeftEdge );
  217.         ng.ng_TopEdge    = OffY + ComputeY( ng.ng_TopEdge );
  218.         ng.ng_Width      = ComputeX( ng.ng_Width );
  219.         ng.ng_Height     = ComputeY( ng.ng_Height);
  220.  
  221.         TextGadgets[ lc ] = g = CreateGadgetA((ULONG)TextGTypes[ lc ], g, &ng, ( struct TagItem * )&TextGTags[ tc ] );
  222.  
  223.         while( TextGTags[ tc ] ) tc += 2;
  224.         tc++;
  225.  
  226.         if ( NOT g )
  227.             return( 2L );
  228.     }
  229.  
  230.     if ( ! ( TextWnd = OpenWindowTags( NULL,
  231.                 WA_Left,    wleft,
  232.                 WA_Top,        wtop,
  233.                 WA_Width,    ww + OffX + Scr->WBorRight,
  234.                 WA_Height,    wh + OffY + Scr->WBorBottom,
  235.                 WA_IDCMP,    STRINGIDCMP|BUTTONIDCMP|TEXTIDCMP|NUMBERIDCMP|SLIDERIDCMP|CYCLEIDCMP|IDCMP_VANILLAKEY|IDCMP_REFRESHWINDOW,
  236.                 WA_Flags,    WFLG_DRAGBAR|WFLG_DEPTHGADGET|WFLG_SMART_REFRESH|WFLG_ACTIVATE|WFLG_RMBTRAP,
  237.                 WA_Gadgets,    TextGList,
  238.                 WA_Title,    TextWdt,
  239.                 WA_ScreenTitle,    "Text Prefs",
  240.                 WA_PubScreen,    Scr,
  241.                 TAG_DONE )))
  242.     return( 4L );
  243.  
  244.     GT_RefreshWindow( TextWnd, NULL );
  245.  
  246.     return( 0L );
  247. }
  248.  
  249. void CloseTextWindow( void )
  250. {
  251.     if ( TextWnd        ) {
  252.         CloseWindow( TextWnd );
  253.         TextWnd = NULL;
  254.     }
  255.  
  256.     if ( TextGList      ) {
  257.         FreeGadgets( TextGList );
  258.         TextGList = NULL;
  259.     }
  260.  
  261.     if ( TextFont ) {
  262.         CloseFont( TextFont );
  263.         TextFont = NULL;
  264.     }
  265. }
  266.  
  267.